

## Arquitectura FPGAs Xilinx

## Objetivos

- Entender como se logra implementar el hardware reconfigurable en una FPGA.
- Obtener el conocimiento para entender la arquitectura de una FPGA específica.
- Conocer la arquitectura básica de la FPGA a utilizar en los trabajos prácticos de la materia (SPARTAN 3 – SPARTAN6)

## ¿Qué vamos a ver?

- Arquitectura básica de las FPGAs de Xilinx.
  - Configurable Logic Blocks (CLBs)
  - Input / Output Blocks (IOBs)
  - Block Ram
  - Multiplier Blocks
  - Digital Clock Manager (DCM)
- Arquitectura básica FPGA Xilinx SPARTAN 3, SPARTAN 6

## Arquitectura de FPGA: Xilinx Spartan 3E

## Bloques básicos



## Xilinx Spartan 3E Input/Output Blocks

Table 6: Single-Ended IOSTANDARD Bank Compatibility

|                            | V <sub>CCO</sub> Supply/Compatibility Input Requireme |                  |                  |                  |                  |                    |                                                    |  |  |  |
|----------------------------|-------------------------------------------------------|------------------|------------------|------------------|------------------|--------------------|----------------------------------------------------|--|--|--|
| Single-Ended<br>IOSTANDARD | 1.2V                                                  | 1.5V             | 1.8V             | 2.5V             | 3.3V             | V <sub>REF</sub>   | Board<br>Termination<br>Voltage (V <sub>TT</sub> ) |  |  |  |
| LVTTL                      | -                                                     | -                | -                | -                | Input/<br>Output | N/R <sup>(1)</sup> | N/R                                                |  |  |  |
| LVCMOS33                   | -                                                     | -                | -                | -                | Input/<br>Output | N/R                | N/R                                                |  |  |  |
| LVCMOS25                   | -                                                     | -                | -                | Input/<br>Output | Input            | N/R                | N/R                                                |  |  |  |
| LVCMOS18                   | -                                                     | -                | Input/<br>Output | Input            | Input            | N/R                | N/R                                                |  |  |  |
| LVCMOS15                   | -                                                     | Input/<br>Output | Input            | Input            | Input            | N/R                | N/R                                                |  |  |  |
| LVCMOS12                   | Input/<br>Output                                      | Input            | Input            | Input            | Input            | N/R                | N/R                                                |  |  |  |
| PCl33_3                    | -                                                     | -                | -                | -                | Input/<br>Output | N/R                | N/R                                                |  |  |  |
| PCI66_3                    | •                                                     |                  | -                | -                | Input/<br>Output | N/R                | N/R                                                |  |  |  |
| HSTL_I_18                  | -                                                     | -                | Input/<br>Output | Input            | Input            | 0.9                | 0.9                                                |  |  |  |
| HSTL_III_18                | •                                                     | •                | Input/<br>Output | Input            | Input            | 1.1                | 1.8                                                |  |  |  |
| SSTL18_I                   | -                                                     | -                | Input/<br>Output | Input            | Input            | 0.9                | 0.9                                                |  |  |  |
| SSTL2_I                    | -                                                     | -                | -                | Input/<br>Output | Input            | 1.25               | 1.25                                               |  |  |  |

## Notes:

1. N/R - Not required for input operation.

Table 7: Differential IOSTANDARD Bank Compatibility

| Differential                      | V <sub>CCO</sub> Supply |                                                       |       |  |  |  |  |  |  |
|-----------------------------------|-------------------------|-------------------------------------------------------|-------|--|--|--|--|--|--|
| IOSTANDARD                        | 1.8V                    | 2.5V                                                  | 3.3V  |  |  |  |  |  |  |
| LVDS_25                           | Input                   | Input,<br>On-chip Differential Termination,<br>Output | Input |  |  |  |  |  |  |
| RSDS_25                           | Input                   | Input,<br>On-chip Differential Termination,<br>Output | Input |  |  |  |  |  |  |
| MINI_LVDS_25                      | Input                   | Input,<br>On-chip Differential Termination,<br>Output | Input |  |  |  |  |  |  |
| LVPECL_25                         | Input                   | Input                                                 | Input |  |  |  |  |  |  |
| BLVDS_25                          | Input                   | Input,<br>Output                                      | Input |  |  |  |  |  |  |
| DIFF_HSTL_I_18                    | Input,<br>Output        | Input                                                 | Input |  |  |  |  |  |  |
| DIFF_HSTL_III_18 Input,<br>Output |                         | Input                                                 | Input |  |  |  |  |  |  |
| DIFF_SSTL18_I                     | Input,<br>Output        | Input                                                 | Input |  |  |  |  |  |  |
| DIFF_SSTL2_I                      | Input                   | Input,<br>Output                                      | Input |  |  |  |  |  |  |

| Input<br>Requirements:<br>V <sub>REF</sub>              | Differential Bank<br>Restriction <sup>(1)</sup>                                        |
|---------------------------------------------------------|----------------------------------------------------------------------------------------|
|                                                         | Applies to Outputs<br>Only                                                             |
|                                                         | Applies to Outputs<br>Only                                                             |
|                                                         | Applies to Outputs<br>Only                                                             |
| V <sub>REF</sub> is not used for<br>these I/O standards |                                                                                        |
|                                                         | No Differential Bank<br>Restriction<br>(other I/O bank<br>restrictions might<br>apply) |

## Notes:

<sup>1.</sup> Each bank can support any two of the following: LVDS\_25 outputs, MINI\_LVDS\_25 outputs, RSDS\_25 outputs.

- Slew Rate Control
  - SLOW / FAST
- Drive Strength
- Operault:
  - LVCMOS25
  - SLOW slew rate
  - 12 mA

Table 8: Programmable Output Drive Current

| IOSTANDARD | Output Drive Current (mA) |   |   |   |    |    |  |  |  |  |
|------------|---------------------------|---|---|---|----|----|--|--|--|--|
| IOSTANDARD | 2                         | 4 | 6 | 8 | 12 | 16 |  |  |  |  |
| LVTTL      | ~                         | ~ | ~ | ~ | ~  | ~  |  |  |  |  |
| LVCMOS33   | ~                         | ~ | ~ | ~ | ~  | ~  |  |  |  |  |
| LVCMOS25   | ~                         | ~ | ~ | ~ | ~  | -  |  |  |  |  |
| LVCMOS18   | ~                         | ~ | ~ | ~ | -  | -  |  |  |  |  |
| LVCMOS15   | ~                         | ~ | ~ | - | -  | -  |  |  |  |  |
| LVCMOS12   | ~                         | - | - | - | -  | -  |  |  |  |  |

 Usar el MENOR slew rate y Drive Strength que la aplicación necesite.

- o I/O Banks:
  - Spartan 3E: 4 Bancos
  - Cada banco tiene su propio Vref y VCCo



Figure 13: Spartan-3E I/O Banks (top view)

## Xilinx Spartan 3E Configurable Logic Blocks

## LC (Logic cell)

Xilinx Logic cell (LC):

Contiene una LUT de 4 entradas, un multiplexor y un registro.

Se puede configurar la polaridad del clock, el clock enable y la Señal de reset



## **SLICE**

- Slice es el elemento que sigue a los LC en la jerarquía de Xilinx.
- Contiene dos logic Cells
  - Hay Slices que contienen mas, dependiendo de la arquitectura de la FPGA



## Xilinx CLB

- Configurable Logic Block (CLB)
- o CLB es el elemento que sigue en la jerarquia a los slices.



## Spartan 3E: CLBs

- Cada CLB contiene 4 Slices
- Cada Slice contiene 2 LUT y 2 elementos de memoria (Flip-Flop o Latch).
- Cada LUT se puede configurar como memoria 16x1 (RAM16) o shift register de 16 bit (SRL16)



Figure 14: CLB Locations

## Spartan 3E: CLBs

 La combinación de una LUT + Elemento de memoria se llama "Logic Cell"





## Distributed RAM and Shift Registers

Cada LUT se puede usar como una 16\*1 RAM. Si asumimos 4 slices por CLB, las distintas configuraciones de RAM son:

```
■ Single-port 16 × 8 bit RAM
```

Además cada LUT se puede usar como un shift register de 16 bit.

## Xilinx Otros recursos

## Embedded multipliers, adders and MAC

 Algunas funciones como las multiplicaciones son muy lentas si se implementan mediante la conexión de un gran numero de bloques lógicos. Por eso se incorporan bloques multiplicadores hardwired. Estos bloques se encuentran muy cerca de los bloques de RAM embebidos.



Figure 4-11. Bird's-eye view of chip with columns of embedded multipliers and RAM blocks.



Figure 4-12. The functions forming a MAC.

## Digital Clock Managers (DCM)

El Digital Clock Manager se usa para generar un número determinado



## Digital Clock Manager (DCM)

Se usa para:

• Remover el jitter



## Clock Manager (DCM)

 Phase shifting: algunos diseños requieren clocks que estén corridos en fase unos con respecto a otros.



## Spartan 3E

## Spartan 3E

- Fabricado en proceso de 90 nm.
- Capacidades entre 50K y 50M de puertas equivalentes (XC3S50, XC3S200, XC3S400, XC3S1000, XC3S1500 y XC3S4000)
- 1.28Mbits de BlockRAM
- Rango de E/S: desde 124 a 784 pines para cada dispositivo
- Gestión digital del reloj (DCM)
- Multiplicadores de 18x18bits
- Soporte de núcleos procesadores como soft IPs (Xilinx 32-bit MicroBlaze y 8-bit PicoBlaze)

## Spartan 3E

- Frecuencia máxima de reloj de 326 MHz
- Tres tensiones de alimentación:1.2V para el core, 1.2V a 3.3 V para E/S, y 2.5 V para las funciones especiales
- Hasta 376 E/S a 622Mb/s, soporte de E/S (LVDS, DCI, DDR)

- CLBs total < Rows \* Columns</p>
- Slices = CLB \* 4
- LUT = Flip-Flop = Slices \* 2
- RAMI6 = SRLI6 = Slices
- Eq Logic Cell =~ Slices \* 2,25
  - Cada Slice además de LUTs + Flip-Flops tiene Mutiplicadores, Lógica de Carry y compuertas aritméticas

| Device    | CLB<br>Rows | CLB<br>Columns | CLB<br>Total <sup>(1)</sup> | Slices | LUTs /<br>Flip-Flops | Equivalent<br>Logic Cells | RAM16 /<br>SRL16 | Distributed<br>RAM Bits |
|-----------|-------------|----------------|-----------------------------|--------|----------------------|---------------------------|------------------|-------------------------|
| XC3S100E  | 22          | 16             | 240                         | 960    | 1,920                | 2,160                     | 960              | 15,360                  |
| XC3S250E  | 34          | 26             | 612                         | 2,448  | 4,896                | 5,508                     | 2,448            | 39,168                  |
| XC3S500E  | 46          | 34             | 1,164                       | 4,656  | 9,312                | 10,476                    | 4,656            | 74,496                  |
| XC3S1200E | 60          | 46             | 2,168                       | 8,672  | 17,344               | 19,512                    | 8,672            | 138,752                 |
| XC3S1600E | 76          | 58             | 3,688                       | 14,752 | 29,504               | 33,192                    | 14,752           | 236,032                 |

| Device    | System | Equivalent  | (    | CLB one CLB = | Array<br>Four Slic | es)             | Distributed             | Block<br>RAM        | Dedicated   | DCMe   Maximum   Di |          | Maximum<br>Differential |
|-----------|--------|-------------|------|---------------|--------------------|-----------------|-------------------------|---------------------|-------------|---------------------|----------|-------------------------|
| Gat       | Gates  | Logic Cells | Rows | Columns       | Total<br>CLBs      | Total<br>Slices | RAM bits <sup>(1)</sup> | bits <sup>(1)</sup> | Multipliers | DCIVIS              | User I/O | I/O Pairs               |
| XC3S100E  | 100K   | 2,160       | 22   | 16            | 240                | 960             | 15K                     | 72K                 | 4           | 2                   | 108      | 40                      |
| XC3S250E  | 250K   | 5,508       | 34   | 26            | 612                | 2,448           | 38K                     | 216K                | 12          | 4                   | 172      | 68                      |
| XC3S500E  | 500K   | 10,476      | 46   | 34            | 1,164              | 4,656           | 73K                     | 360K                | 20          | 4                   | 232      | 92                      |
| XC3S1200E | 1200K  | 19,512      | 60   | 46            | 2,168              | 8,672           | 136K                    | 504K                | 28          | 8                   | 304      | 124                     |
| XC3S1600E | 1600K  | 33,192      | 76   | 58            | 3,688              | 14,752          | 231K                    | 648K                | 36          | 8                   | 376      | 156                     |

## Spartan 6

## Spartan 6: CLBs

- Cada CLB tiene 2 Slices
- Hay 3 tipos de Slices
  - SLICEM
  - SLICEL
  - SLICEX
- Cada Slice tiene 4 LUTs, 8 Flip-Flops y otros elementos.

## Spartan 6: CLBs - SLICEM

- 25% de los Slices son de este tipo.
- Cada una de las 4 LUTs se puede configurar como,
  - o 6 entradas 1 salida
  - o 5 entradas 2 salidas
  - o 64x1 o 32x2 RAM
  - 32 bit o 2x 16 bits Shift Register

## Spartan 6: CLBs - SLICEL

- 25% de los Slices son de este tipo.
- Todo lo de la SLICEM menos las funciones de Memoria / Shift

## Spartan 6: CLBs - SLICEX

- 50% de los Slices son de este tipo.
- Todo lo de la SLICEL menos las funciones de Carry

## Spartan 6: Otros recursos

- Memory Controller Block
  - Controlador de DDR, DDR2, DDR3 800 Mb/s
- DSP48A1 Slice
  - Multiplicador 18\*18 bits @390 MHz
  - Acumulador 48 bits @390 MHz

## Spartan 6

| Device Logic<br>Cells <sup>(1)</sup> |                               | Configural | ble Logic Bl | ocks (CLBs)                    |                                  | Block RA | M Blocks |                     | Memory                                       | Endpoint                  | Maximum             | Total        | Max         |
|--------------------------------------|-------------------------------|------------|--------------|--------------------------------|----------------------------------|----------|----------|---------------------|----------------------------------------------|---------------------------|---------------------|--------------|-------------|
|                                      | Logic<br>Cells <sup>(1)</sup> | Slices(2)  | Flip-Flops   | Max<br>Distributed<br>RAM (Kb) | DSP48A1<br>Slices <sup>(3)</sup> | 18 Kb(4) | Max (Kb) | CMTs <sup>(5)</sup> | Controller<br>Blocks<br>(Max) <sup>(6)</sup> | Blocks for<br>PCI Express | GTP<br>Transceivers | I/O<br>Banks | User<br>I/O |
| XC6SLX4                              | 3,840                         | 600        | 4,800        | 75                             | 8                                | 12       | 216      | 2                   | 0                                            | 0                         | 0                   | 4            | 132         |
| XC6SLX9                              | 9,152                         | 1,430      | 11,440       | 90                             | 16                               | 32       | 576      | 2                   | 2                                            | 0                         | 0                   | 4            | 200         |
| XC6SLX16                             | 14,579                        | 2,278      | 18,224       | 136                            | 32                               | 32       | 576      | 2                   | 2                                            | 0                         | 0                   | 4            | 232         |
| XC6SLX25                             | 24,051                        | 3,758      | 30,064       | 229                            | 38                               | 52       | 936      | 2                   | 2                                            | 0                         | 0                   | 4            | 266         |
| XC6SLX45                             | 43,661                        | 6,822      | 54,576       | 401                            | 58                               | 116      | 2,088    | 4                   | 2                                            | 0                         | 0                   | 4            | 358         |
| XC6SLX75                             | 74,637                        | 11,662     | 93,296       | 692                            | 132                              | 172      | 3,096    | 6                   | 4                                            | 0                         | 0                   | 6            | 408         |
| XC6SLX100                            | 101,261                       | 15,822     | 126,576      | 976                            | 180                              | 268      | 4,824    | 6                   | 4                                            | 0                         | 0                   | 6            | 480         |
| XC6SLX150                            | 147,443                       | 23,038     | 184,304      | 1,355                          | 180                              | 268      | 4,824    | 6                   | 4                                            | 0                         | 0                   | 6            | 576         |
| XC6SLX25T                            | 24,051                        | 3,758      | 30,064       | 229                            | 38                               | 52       | 936      | 2                   | 2                                            | 1                         | 2                   | 4            | 250         |
| XC6SLX45T                            | 43,661                        | 6,822      | 54,576       | 401                            | 58                               | 116      | 2,088    | 4                   | 2                                            | 1                         | 4                   | 4            | 296         |
| XC6SLX75T                            | 74,637                        | 11,662     | 93,296       | 692                            | 132                              | 172      | 3,096    | 6                   | 4                                            | 1                         | 8                   | 6            | 348         |
| XC6SLX100T                           | 101,261                       | 15,822     | 126,576      | 976                            | 180                              | 268      | 4,824    | 6                   | 4                                            | 1                         | 8                   | 6            | 498         |
| XC6SLX150T                           | 147,443                       | 23,038     | 184,304      | 1,355                          | 180                              | 268      | 4,824    | 6                   | 4                                            | 1                         | 8                   | 6            | 540         |

# Links www.xilinx.com